草庐IT

java - Play 的延续持有 http 线程

全部标签

ruby - 如何使用 Net::HTTP 只读取正文的 x 个字节?

在读取网页正文时,Ruby的Net::HTTP方法似乎是全有或全无。例如,我如何读取正文的前100个字节?如果请求的文件不可用,我正在尝试从内容服务器读取内容服务器,该内容服务器会在响应正文中返回一条简短的错误消息。我需要阅读足够多的正文以确定文件是否存在。文件很大,所以我不想让整个body只是为了检查文件是否可用。 最佳答案 这是一个旧线程,但根据我的研究,如何在Ruby中通过HTTP只读取文件的一部分的问题仍然是一个大部分没有答案的问题。这是我通过猴子修补Net::HTTP得到的一个解决方案:require'net/http'#

ruby - 在 Ruby 中,使用 "net/http",我们必须加入 url 并自己使用 "?"进行查询?

在下面的代码中,我们必须使用?字符加入url.path和url.query吗?有更优雅的方法吗?我必须使用net/http,因为在某些情况下我也想在用户代理的header中放置一个字符串。require'net/http'url_string='http://www.time.gov/timezone.cgi?Pacific/d/-8'url=URI.parse(url_string)response=Net::HTTP.start(url.host,url.port)do|http|http.get(url.path+'?'+url.query)endputsresponse.bod

ruby - 如何从 ruby​​ 线程获取错误消息

我现在遇到了一个问题,我无法看到我的子线程在哪里吐出错误消息,这使得调试变得困难。例如:Thread.new{a=1/0}有什么方法可以在标准错误中打印出所有线程错误吗? 最佳答案 将Thread类的abort_on_exception标志设置为true。或者,将线程主体包裹在throw/catchblock中,并将异常转储到catch中。 关于ruby-如何从ruby​​线程获取错误消息,我们在StackOverflow上找到一个类似的问题: https:/

ruby-on-rails - 在 Rails 4 中显示或获取 HTTP header 属性

我有一个用Rails开发的应用程序,我想查看HTTPheader中的属性。有没有办法读取这些属性?它们存储在哪里?有人提到了request.headers。这样对吗?我看不到此数组中的任何属性。 最佳答案 request.headers不返回散列,而是返回ActionDispatch::Http::Headers的实例,它是rackenv的包装器。ActionDispatch::Http::Headers实现了很多方法,比如[]和[]=,这使得它表现得像一个散列,但是它不会覆盖默认的inspect,因此您无法仅通过p或pp查看键值对

ruby-on-rails - 从字符串中删除 "www", "http://"

如何使用Ruby从字符串中删除“www”、“http://”、“https://”?我试过了,但没用:s.gsub('/(?:http?:\/\/)?(?:www\.)?(.*)\/?$/i','')这是我在Rails中所做的:URL被截断了,但我的目标是删除链接的开头,例如“www”或“http://”,这样链接看起来像“google.com/somepage/d...”,不像“http://google.com/some...” 最佳答案 s=s.sub(/^https?\:\/\//,'').sub(/^www./,'')如果

ruby-on-rails - Rails 中的多线程 : Circular dependency detected while autoloading constant

我有一个Rails应用程序,其中有一个Rake任务,该任务使用并发rubygem提供的多线程函数。有时我会遇到Circulardependencydetectedwhileautoloadingconstant错误。在谷歌搜索了一下后,我发现这与结合使用线程和加载Rails常量有关。我偶然发现了以下GitHub问题:https://github.com/ruby-concurrency/concurrent-ruby/issues/585和https://github.com/rails/rails/issues/26847如此处所述,您需要将从新线程调用的所有代码包装在Rails.a

ruby - 线程池中的死锁

我找不到适合Ruby的ThreadPool实现,所以我写了我的(部分基于这里的代码:http://web.archive.org/web/20081204101031/http://snippets.dzone.com:80/posts/show/3276,但更改为等待/信号和ThreadPool关闭的其他实现。但是在运行一段时间后(有100个线程并处理大约1300个任务),它在第25行死锁-它在那里等待新工作。任何想法,为什么会发生?require'thread'beginrequire'fastthread'rescueLoadError$stderr.puts"Usingther

ruby-on-rails - ActionDispatch::Http::UploadedFile.content_type 未在 Rspec 测试中初始化

背景:我有一个带有cover_file属性的Book模型,该模型通过我的一个RailsController使用上传的文件进行设置。我正在使用Railsv4.0.4。目标:我想测试只保存具有特定内容类型的文件。我计划使用设置了不同content_type属性的ActionDispatch::Http:UploadedFile对象创建Rspec测试示例。问题:当我用content_type初始化一个新的ActionDispatch::Http::UploadedFile时,它似乎没有被设置(请参阅下面的测试和输出,确认它为零)。看来我只能在UploadedFile初始化后用setter设置

ruby - 在 Ruby 中生成 HTTP 响应

我正在开发一个连接到Web服务的应用程序。我想开发一个从服务返回虚假响应的代理类,这样我就不必在开发/测试应用程序的其他部分时不断地向它发出请求。我的应用程序期望通过Net::HTTP生成响应。response=Net::HTTP.get(URI.parse('http://foo.com'))caseresponsewhenNet::HTTPOK#dosomethingfunwhenNet::HTTPUnauthorized#yougettheidea我怎样才能制造一个响应对象,给它所有正确的header,返回一个正文字符串,等等?response=ProxyClass.respon

ruby-on-rails - 如何在 Ruby 中获取 http 请求的内容?

在PHP中我可以这样做:$request="http://www.example.com/someData";$response=file_get_contents($request);我如何在Ruby(或某些Rails方法)中做同样的事情?我在谷歌上搜索了半个小时,结果完全没找到。 最佳答案 标准库包open-uri就是您所追求的:require'open-uri'contents=open('http://www.example.com'){|io|io.read}#orcontents=URI.parse('http://ww